// pages/login/login.js
/**
 * 说明:登录流程
 * 1.收集表单项数据
 * 2.前端验证
    1)验证用户信息是否合法(账户,密码)
    2)前端验证不通过提示用户,不需要发请求给后端
    3)前端验证通过,发请求(携带账号,密码)给服务端
 * 3.后端验证
    1)验证用户是否存在
    2)用户不存在直接返回,用户不存在
    3)用户存在需要验证密码是否正确
    4)密码不正确,返回提示密码不正确
    5)密码正确,返回密码正确信息,并返回对应用户信息
 */
import request from '../.../../../utils/request'
Page({

  /**
   * 页面的初始数据
   */
  data: {
    phone:'',//手机号
    password:''//密码
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

  },
  // 表单项内容发生改变的回调
  handleInput(event){
    // let type = event.currentTarget.id; 
    let type = event.currentTarget.dataset.type;
    this.setData({
      [type]:event.detail.value
    })
  },
  // 登录的回调
  async login(){
    // 收集表单项数据
    let {phone,password} = this.data;
    // 前端验证
    /**
     * 手机号验证
     * 1.内容为空
     * 2.手机号格式不正确
     * 3.手机号格式正确,验证通过
     */
    if(!phone){
      // 提示用户
      wx.showToast({
        title: '手机号不能为空',
        icon:'none'
      })
      return
    }
    // 定义手机号正则表达式
    let phoneReg = /^1(3|4|5|6|7|8|9)d{9}$/
    if(phoneReg.test(phone)){
      wx.showToast({
        title: '手机号格式错误',
        icon:'none'
      })
      return
    }
    if(!password){
      wx.showToast({
        title: '密码不能为空',
        icon:'none'
      })
      return
    }
    let result = await request('login/cellphone',{phone,password})
    if(result.code === 200){
      wx.showToast({
        title: '登陆成功',
      })
      // 跳转至个人中心
      // wx.redirectTo({
      //   url: 'pages/personal/personal',
      // })
      // 将用户信息存储至本地
      wx.setStorage('userInfo',JSON.stringify(result.profile))
      // 专门用于跳转tabar的,但是不会销毁其他页面
      // wx.switchTab({
      //   url: '/pages/personal/personal',
      // })
      // 销毁其他页面,跳转至新页面
      wx.reLaunch({
        url: '/pages/personal/personal',
      })
    }else if(result.code === 400){
      wx.showToast({
        title: '手机号错误',
        icon:'none'
      })
    }else if(result.code === 502){
      wx.showToast({
        title: '密码错误',
        icon:'none'
      })
    }else{
      wx.showToast({
        title: '登录失败,请重新登录',
        icon:'none'
      })
    }
  },
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})